package com.huike.report.mapper;


import com.huike.report.domain.vo.BusinessChangeStatisticsVo;
import com.huike.report.domain.vo.SalesStatisticVo;
import com.huike.report.domain.vo.SubjectStatisticsVo;
import com.huike.report.domain.vo.VulnerabilityMapVo;
import org.apache.ibatis.annotations.Param;

import java.util.Date;
import java.util.List;
import java.util.Map;

/**
 * 首页统计分析的Mapper
 * @author Administrator
 *
 */
public interface ReportMapper {
	/**=========================================基本数据========================================*/
	/**
	 * 获取线索数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
    Integer getCluesNum(@Param("startTime") String beginCreateTime,
						@Param("endTime") String endCreateTime,
						@Param("username") String username);

	/**
	 * 获取商机数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Integer getBusinessNum(@Param("startTime") String beginCreateTime,
						   @Param("endTime") String endCreateTime,
						   @Param("username") String username);

	/**
	 * 获取合同数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Integer getContractNum(@Param("startTime") String beginCreateTime,
						   @Param("endTime") String endCreateTime,
						   @Param("username") String username);

	/**
	 * 获取合同金额
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Double getSalesAmount(@Param("startTime") String beginCreateTime,
						  @Param("endTime") String endCreateTime,
						  @Param("username") String username);

	/**=========================================今日简报========================================*/

	/**
	 * 获取线索数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username			用户名
	 * @return
	 */
	Integer getTodatCluesNum(@Param("startTime") String beginCreateTime,
						@Param("endTime") String endCreateTime,
						@Param("username") String username,
							 @Param("now") Date now);


	/**
	 * 获取商机数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @param now 今日时间
	 * @return
	 */
	Integer getTodatbusinessNum(@Param("startTime") String beginCreateTime,
							 @Param("endTime") String endCreateTime,
							 @Param("username") String username,
							 @Param("now") Date now);


	/**
	 * 获取合同数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @param now 今日时间
	 * @return
	 */
	Integer getTodatContractNum(@Param("startTime") String beginCreateTime,
								@Param("endTime") String endCreateTime,
								@Param("username") String username,
								@Param("now") Date now);


	/**
	 * 获取合同数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @param now 今日时间
	 * @return
	 */
	Double getTodatSalesAmount(@Param("startTime") String beginCreateTime,
								@Param("endTime") String endCreateTime,
								@Param("username") String username,
								@Param("now") Date now);

	/**=========================================待办========================================*/

	/**
	 * 待跟进线索数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @return
	 */
	Integer getTofollowedCluesNum(@Param("startTime") String beginCreateTime,
								  @Param("endTime") String endCreateTime,
								  @Param("username") String username);



	/**
	 * 待跟进商机数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @return
	 */
	Integer getTofollowedBusinessNum(@Param("startTime") String beginCreateTime,
						   @Param("endTime") String endCreateTime,
						   @Param("username") String username);



	/**
	 * 待分配线索数目
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @return
	 */
	Integer getToallocatedCluesNum(@Param("startTime") String beginCreateTime,
								  @Param("endTime") String endCreateTime,
								  @Param("username") String username);

	/**
	 * 待分配商机数目
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param username	用户名
	 * @return
	 */
	Integer getToallocatedBusinessNum(@Param("startTime") String beginCreateTime,
								   @Param("endTime") String endCreateTime,
								   @Param("username") String username);

	/**==================================学科客户分布饼图===============================================*/
	/**
	 * 学科的合同数量
	 * @param beginCreateTime	开始时间
	 * @param endCreateTime		结束时间
	 * @param
	 * @return
	 */
	List<SubjectStatisticsVo> getContractNumAndSubject(@Param("startTime") String beginCreateTime,
													   @Param("endTime") String endCreateTime);

	/**
	 * 根据subject查询对应的学科分类名
	 * @param subject
	 * @return
	 */
	String selectNameBySubjicet(String subject);

	/**==================================线索转化率漏斗图===============================================*/

	/**
	 * 有效线索数
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	VulnerabilityMapVo getVulnerabilityMap(@Param("beginCreateTime") String beginCreateTime,
										   @Param("endCreateTime") String endCreateTime);

	/**==================================商机转化龙虎榜接口===============================================*/

	/**
	 * 商机转化数量
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	List<BusinessChangeStatisticsVo> getbusinessChangeStatistics(@Param("beginCreateTime") String beginCreateTime,
																 @Param("endCreateTime") String endCreateTime);


	/**
	 * 时间段内的商机数量
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	Integer getTotalBusinessNum(@Param("beginCreateTime") String beginCreateTime,
								@Param("endCreateTime") String endCreateTime);




	/**==================================线索转化龙虎榜接口===============================================*/
	/**
	 * 线索转化商机数量
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	List<SalesStatisticVo> getSalesStatistic(@Param("beginCreateTime") String beginCreateTime,
											   @Param("endCreateTime") String endCreateTime);


	/**
	 * 线索数量
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	Integer getClueNum(@Param("beginCreateTime") String beginCreateTime, @Param("endCreateTime") String endCreateTime);



	/**========================================新增线索数量折线图========================================*/
	/**
	 * 获取每天新增的线索数量
	 * @param beginCreateTime
	 * @param endCreateTime
	 * @return
	 */
	List<Map<String,Object>> getClueNumAndDate(@Param("beginCreateTime") String beginCreateTime, @Param("endCreateTime") String endCreateTime);
}
